package com.qr.service.wmyh.impl;

import java.util.List;
import java.util.Map;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.apache.ibatis.mapping.ResultMapping;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import cn.krui.helper.db.DBHelper;
import cn.krui.helper.db.DataPage;
import com.qr.bean.wmyh.JbrUserComment;
import com.qr.bean.wmyh.JbrUserCommentView;
import com.qr.controller.WmyhBase;
import com.qr.mapper.wmyh.JbrUserCommentMapper;
import com.qr.mapper.wmyh.JbrUserCommentMapperView;
import com.qr.service.wmyh.JbrUserCommentService;
//import org.apache.dubbo.config.annotation.Service;

/**
 * @author: zc
 * email: zc8023zs@163.com
 * create_time: 2020/8/11 13:02:32
 */
@Service
//@Service(version = "1.0.0",group="dubbo")
public class JbrUserCommentServiceImpl implements JbrUserCommentService{
    @Autowired
    private JbrUserCommentMapper jbrUserCommentMapper;

    @Autowired
    private JbrUserCommentMapperView jbrUserCommentMapperView;
    
    @Autowired
    private DBHelper dbHelper;

    /**
     * 构造查询条件
     */
    private QueryWrapper<JbrUserComment> InitWrapper(JbrUserComment where){
        QueryWrapper<JbrUserComment> whereWrapper = new QueryWrapper<JbrUserComment>();
        if(where.getId()!=null){
			whereWrapper.eq("id",where.getId());
		}
        if(where.getUser_id()!=null){
			whereWrapper.eq("user_id",where.getUser_id());
		}
        if(where.getContent()!=null){
			whereWrapper.eq("content",where.getContent());
		}
        if(where.getNum()!=null){
			whereWrapper.eq("num",where.getNum());
		}
        if(where.getImg()!=null){
			whereWrapper.eq("img",where.getImg());
		}
        if(where.getProduct_id()!=null){
			whereWrapper.eq("product_id",where.getProduct_id());
		}
        if(where.getIs_show()!=null){
			whereWrapper.eq("is_show",where.getIs_show());
		}
        if(where.getIs_best()!=null){
			whereWrapper.eq("is_best",where.getIs_best());
		}
        if(where.getAdd_time()!=null){
			whereWrapper.eq("add_time",where.getAdd_time());
		}
        return whereWrapper;
    }

    private QueryWrapper<JbrUserCommentView> InitWrapperView(JbrUserCommentView where){
        QueryWrapper<JbrUserCommentView> whereWrapper = new QueryWrapper<JbrUserCommentView>();
        if(where.getId()!=null){
			whereWrapper.eq("id",where.getId());
		}
        if(where.getUser_id()!=null){
			whereWrapper.eq("user_id",where.getUser_id());
		}
        if(where.getContent()!=null){
			whereWrapper.eq("content",where.getContent());
		}
        if(where.getNum()!=null){
			whereWrapper.eq("num",where.getNum());
		}
        if(where.getImg()!=null){
			whereWrapper.eq("img",where.getImg());
		}
        if(where.getProduct_id()!=null){
			whereWrapper.eq("product_id",where.getProduct_id());
		}
        if(where.getIs_show()!=null){
			whereWrapper.eq("is_show",where.getIs_show());
		}
        if(where.getIs_best()!=null){
			whereWrapper.eq("is_best",where.getIs_best());
		}
        if(where.getAdd_time()!=null){
			whereWrapper.eq("add_time",where.getAdd_time());
		}
        return whereWrapper;
    }

    /**
     * 用户评论表新增
     * @param model 用户评论表实体
     * @return 影响行数
     */
	@Override
    public Integer add(JbrUserComment model){
        return jbrUserCommentMapper.insert(model);
    }

    /**
     * 用户评论表修改byid
     * @param model 用户评论表实体
     * @return 影响行数
     */
	@Override
    public Integer update(JbrUserComment model) {
        return jbrUserCommentMapper.updateById(model);
    }

    /**
     * 用户评论表修改by条件
     * @param model 用户评论表实体
     * @param where 用户评论表条件
     * @return 影响行数
     */
	@Override
    public Integer update(JbrUserComment model, Wrapper<JbrUserComment> where) {
        return jbrUserCommentMapper.update(model, where);
    }

    /**
     * 用户评论表修改by条件-自动封装Wrapper
     * @param model 用户评论表实体
     * @return 影响行数
     */
	@Override
    public Integer update(JbrUserComment model, JbrUserComment where) {
        Wrapper<JbrUserComment> wrapper = InitWrapper(where);
        return update(model, wrapper);
    }

    /**
     * 用户评论表修改bySQL *version_id = newVersion where version_id = oldVersion
     * @param fields 修改的数据 col1=xx,col2=yy
     * @param where 参数化条件 col1=#{col1}
     * @param params 条件参数 col1=xx
     * @return 影响行数
     */
	@Override
    public Integer update(Map<String, Object> fields, String where, Map<String, Object> params) {
        return dbHelper.update("jbr_user_comment", fields, where, params);
    }

    /**
     * 用户评论表删除byid
     * @param id 用户评论表主键
     * @return 影响行数
     */
	@Override
    public Integer del(int id) {
        return jbrUserCommentMapper.deleteById(id);
    }

    /**
     * 用户评论表删除by条件
     * @param where 用户评论表条件
     * @return 影响行数
     */
	@Override
    public Integer del(Wrapper<JbrUserComment> where) {
        return jbrUserCommentMapper.delete(where);
    }

    /**
     * 用户评论表删除by条件-自动封装Wrapper
     * @param where 用户评论表条件
     * @return 影响行数
     */
    @Override
    public Integer del(JbrUserComment where) { 
        Wrapper<JbrUserComment> wrapper = InitWrapper(where);
        return del(wrapper);
    }

    /**
     * 用户评论表批量删除byid
     * @param ids 用户评论表主键集合
     * @return 影响行数
     */
	@Override
    public Integer del(List<Integer> ids){
        return jbrUserCommentMapper.deleteBatchIds(ids);
    }

    /**
     * 用户评论表批量删除bymap条件
     * @param map 用户评论表map条件
     * @return 影响行数
     */
	@Override
    public Integer del(Map<String,Object> map){
        return jbrUserCommentMapper.deleteByMap(map);
    }

    /**
     * 用户评论表详情byid
     * @param id 用户评论表主键
     * @return 用户评论表详情
     */
	@Override
    public JbrUserCommentView info(int id){
        return jbrUserCommentMapperView.selectById(id);
    }

    /**
     * 用户评论表详情by条件
     * @param where 用户评论表条件
     * @return 用户评论表详情
     */
	@Override
    public JbrUserCommentView info(Wrapper<JbrUserCommentView> where){
        return jbrUserCommentMapperView.selectOne(where);
    }

    /**
     * 用户评论表详情by条件-自动封装Wrapper
     * @param where 用户评论表条件
     * @return 用户评论表详情
     */
	@Override
    public JbrUserCommentView info(JbrUserCommentView where) {
        Wrapper<JbrUserCommentView> wrapper = InitWrapperView(where);
        return info(wrapper);
    }

    /**
     * 用户评论表详情bySQL
     * @param columns  列名col1,col2,col3^
     * @param where 条件 col1=#{col1}
     * @param params col1:xx
     * @param mappings col1->col1
     * @return
     */
	@Override
    public JbrUserComment info(String columns, String where, Map<String, Object> params, ResultMapping mappings) {
        return dbHelper.selectOne(columns, "jbr_user_comment", where, params, JbrUserComment.class, mappings);
    }

    /**
     * 用户评论表批量查询byid
     * @param ids 用户评论表主键集合
     * @return 用户评论表列表
     */
	@Override
    public List<JbrUserCommentView> select(List<Integer> ids){
        return jbrUserCommentMapperView.selectBatchIds(ids);
    }

    /**
     * 用户评论表批量查询by条件
     * @param where 用户评论表条件
     * @return 用户评论表列表
     */
	@Override
    public List<JbrUserCommentView> select(Wrapper<JbrUserCommentView> where){
        return jbrUserCommentMapperView.selectList(where);
    }

    /**
     * 用户评论表批量查询by条件-自动封装Wrapper
     * @param where 用户评论表条件
     * @return 用户评论表列表
     */
    @Override
    public List<JbrUserCommentView> select(JbrUserCommentView where) {
        Wrapper<JbrUserCommentView> wrapper = InitWrapperView(where);		
        return select(wrapper);
    }

    /**
     * 用户评论表批量查询bymap条件
     * @param map 用户评论表map条件
     * @return 用户评论表列表
     */
	@Override
    public List<JbrUserCommentView> select(Map<String,Object> map){
        return jbrUserCommentMapperView.selectByMap(map);
    }

    /**
     * 用户评论表批量查询b条件分页
     * @param page 分页条件
     * @param where 查询条件
     * @return
     */
	@Override
    public IPage<JbrUserCommentView> select(IPage<JbrUserCommentView> page, Wrapper<JbrUserCommentView> where){
        return jbrUserCommentMapperView.selectPage(page, where);
    }

    /**
     * 用户评论表批量查询b条件分页
     * @param page 分页条件
     * @param where 查询条件
     * @return
     */
    @Override
    public IPage<JbrUserCommentView> select(IPage<JbrUserCommentView> page, JbrUserCommentView where) {
		Wrapper<JbrUserCommentView> wrapper = InitWrapperView(where);		
        return select(page, wrapper);
    }

    /**
     * 用户评论表查询记录数
     * @param where 查询条件
     * @return
     */
	@Override
    public Integer selectCount(Wrapper<JbrUserCommentView> where){
        return jbrUserCommentMapperView.selectCount(where);
    }

    /**
     * 用户评论表查询记录数
     * @param where 查询条件
     * @return
     */
	@Override
    public Integer selectCount(JbrUserCommentView where){
		Wrapper<JbrUserCommentView> wrapper = InitWrapperView(where);
        return selectCount(wrapper);
    }

    /**
     * 用户评论表批量查询bySQL条件分页
     * @param columns 列col1,col2,col3……
     * @param where 条件col1=#{col1} and col2=#{col2}
     * @param orderBy 排序字段
     * @param params 参数化 col1=xx
     * @param pageNumber 分页页码
     * @param pageSize 每页行数
     * @param mappings 查询列和实体映射
     * @return 分页之后的数据含总行数
     */
	@Override
    public DataPage<JbrUserCommentView> select(String columns, String where, String orderBy, Map<String, Object> params, int pageNumber, int pageSize, ResultMapping mappings){
        return dbHelper.select(columns, "jbr_user_comment", where, orderBy, params, pageNumber, pageSize, JbrUserCommentView.class,mappings);
    }

    /**
     * 用户评论表批量查询bySQL条件
     * @param columns 列col1,col2,col3……
     * @param where 条件col1=#{col1} and col2=#{col2}
     * @param params 参数化 col1=xx
     * @param mappings 查询列和实体映射
     * @return 栏目扩展列表
     */
	@Override
    public List<JbrUserCommentView> select(String columns, String where, Map<String, Object> params, ResultMapping mappings){
        return dbHelper.select(columns,"jbr_user_comment",where,params,JbrUserCommentView.class,mappings);
    }
}